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(54) Multiple tickets in smart cards 

(57) The invention provides an efficient way to store 
multiple tickets on smart cards. According to the present 
invention, a ticket (20) comprises a validation count field 
(26) for registering by way of a validation count the 
number of times the ticket may be used. Preferably, the 
validation count is lowered each time the ticket is vali- 
dated, the validation being effected by writing validation 



data in the validation field (22) of the ticket. In this way a 
single ticket can thus be used as a multiple ticket, thus 
saving memory space. The validation count is also 
effective in limiting the number of tickets validated, thus 
limiting the extent of possible fraud. 
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Description 

BACKGROUND OF THE INVENTION 

The present invention relates to a method of using s 
tickets on smart cards, and to smart cards in which tick- 
ets are stored. In particular, the present invention 
relates to the secure storing, validating and verifying of 
multiple tickets on smart cards, multiple tickets being 
tickets which may be used more than once. Such multi- to 
pie tickets may e.g. be bus or train tickets which may be 
used for more than one trip, or theatre tickets which can 
be used for more than one performance or more than 
one person. 

There is a growing need for storing tickets on smart is 
cards as the use of smart cards and the number of 
applications for which they are used increases. Present 
day smart cards, however, have a limited memory size. 
The storing of a plurality of tickets on a single card is 
therefore only feasible if an efficient way of storing those 20 
tickets is employed. Especially multiple tickets, which 
give the cardholder multiple access to e.g. a service, 
take up a relatively large amount of memory space. 
Several schemes of using tickets have been proposed 
in the Prior Art, but none of these appears to provide an 25 
efficient way of storing multiple tickets. 

Dutch patent application NL 93 01902 discloses a 
method of obtaining a right to a service by means of a 
smart card (IC card). In this Prior Art method, the card 
serves both as a payment means and as a registration 30 
means. That is, the card is used to store proof of pay- 
ment of the service paid for, thus replacing paper tick- 
ets. The use of multiple tickets, i.e. tickets which may be 
used more than once, is also mentioned in said patent 
application. 35 

In the method of the above-mentioned patent appli- 
cation, a ticket is stored on a card by registering on the 
card an access code, optionally in combination with a 
card identification code. At the terminal of e.g. a theatre 
the access code and (optionally) the identification code 40 
are checked, whereupon the access code is erased 
from the card. The way multiple tickets are implemented 
is not disclosed. The above-mentioned patent applica- 
tion therefore does not provide a specific method for 
securely storing tickets on smart cards, and certainly 4s 
not for multiple tickets. 

European Patent Application EP 0 658 862 dis- 
closes a method and system for employing multi-func- 
tional smart cards by means of a communication 
system. This prior art method and system allow e.g. air- so 
line tickets to be stored on the smart cards. The specific 
manner in which the tickets are stored is however not 
disclosed. 

European Patent Application 96202240.6, filed 9 
August 1996. describes the use of tickets on smart ss 
cards, in particular the use of validation and verification 
fields to issue, validate and verify tickets at different 
locations and at different points in time respectively. The 



said European Patent Application does not describe the 
use of multiple tickets. 

The Prior Art therefore does not provide an efficient 
way of storing multiple tickets in smart cards. 

SUMMARY OF THE INVENTION 

It is an object of the present invention to overcome 
the above-mentioned and other disadvantages of the 
prior art and to provide a smart card which allows tickets 
to be efficiently stored. It is another object of the present 
invention to provide a smart card which allows a limita- 
tion to be placed on the number of tickets to be issued 
and used. It is a further object of the present invention to 
provide a method of registering multiple tickets on smart 
cards. 

Accordingly, the present invention provides a smart 
card comprising an integrated circuit having a processor 
and a memory, the memory comprising tickets, a ticket 
comprising an entitlement field for storing data relating 
to the entitlement of the ticket, and a validation field for 
storing data relating to the validity of the ticket, the 
smart card being characterized in that a ticket further 
comprises a validation count field for registering the 
number of times the ticket may be validated. 

By providing a validation count field, it is possible to 
validate the same ticket more than once while strictly 
controlling the number of times the ticket may be used. 
As a multiple ticket of this type requires hardly more 
memory space than a regular ticket, a very efficient 
memory use is achieved. 

The present invention also provides a method of 
registering tickets on a smart card comprising a mem- 
ory, the method comprising the steps of: creating a 
ticket in the memory, the ticket comprising at least one 
field, issuing the ticket by storing in the field data identi- 
fying a right to be conveyed by the ticket, validating the 
ticket by storing in a validation field data relating to the 
validity of the ticket, the method being characterized in 
that the step of issuing the ticket comprises storing in a 
validation count field a validation count representing the 
number of times the ticket may be validated, and in that 
the step of validating the ticket comprises adjusting the 
validation count stored in the validation count field, said 
adjusting as well as the step of validating the ticket 
being inhibited if the validation count has a predeter- 
mined value. 

BRIEF DESCRIPTION OF THE DRAWINGS 

The invention will further be explained with refer- 
ence to the accompanying drawings, in which: 

Fig. 1 schematically shows a smart card as may be 
used in the method of the present invention, 
Fig. 2 schematically shows the integrated circuit of 
the smart card of Fig. 1 , 

Fig. 3 schematically shows the structure of a ticket 
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as stored in a smart card, 

Fig. 4 shows a flow diagram representing the 

method of the present invention, 

Fig. 5 schematically shows a terminal in which the 

method of the present invention may be utilized, s 

and 

Fig. 6 shows a diagram representing the exchange 
of data between a card, a card reader and a secu- 
rity module. 

Fig. 7 schematically shows a security module of a 10 
terminal in which issue limits are kept. 

EXEMPLARY EMBODIMENTS 

The smart card or IC card 1 shown schematically is 
and by way of example in Fig. 1 comprises a substrate 
2, in which an integrated circuit is embedded. The inte- 
grated circuit is provided with contacts 3 for contacting a 
card reader or the like. It should be noted that the 
present invention can also be applied in the case of so- 20 
called contactless smart cards. 

The integrated circuit 10 shown schematically and 
by way of example in Fig. 2 comprises a processor 11, 
a memory 12 and an input/output circuit 13. The mem- 
ory may comprise a volatile (RAM) memory part for 25 
temporarily storing data and a non-volatile (ROM) mem- 
ory part for permanently or semi-permanently storing 
data. The latter part is preferably an EEPROM type 
memory. The data stored in the non-volatile part may 
contain both programming data (instructions, programs) 30 
and payment data, i.e. data relating to monetary trans- 
actions. It will be understood that a separate memory 
(not shown) may be provided to store the instruction set 
of the processor 1 1 . 

A preferred embodiment of a ticket according to the 35 
present invention is schematically shown in Fig. 3. The 
ticket 20 comprises several fields, i.e. an entitlement 
field 21, a validation field 22, a verification field 23, a 
price field 24, a sequence number field 25, and a valida- 
tion count field 26. In practice, a ticket may comprise ao 
additional fields which are not shown in Fig. 3. Also, a 
ticket according to the present invention may comprise 
less fields, or more fields of the same type, e.g. two ver- 
ification fields. For the purpose of the present invention, 
the entitlement field 21, the validation field 22 and the <s 
validation count field 26 are primarily of importance. 

The entitlement field 21 contains the description of 
the ticket which may include e.g. the identity of the ticket 
issuer, the scope of validity (e.g. an expiry date, the 
maximum length of a trip), the number of persons the so 
ticket is valid for, and/or the starting point and destina- 
tion of a trip. 

The validation field 22 is reserved for information 
which may be added later to the ticket, such as a start- 
ing time and/or date of validity. 55 

The verification field 23 is reserved for information 
which may be added during the use of the ticket, such 
as the date, the time, and a terminal identification. This 



information provides a "marking" of the ticket which indi- 
cates that a check of the ticket with respect to the valid- 
ity has taken place. A code identifying a particular 
means of transportation (e.g. a train code) may also be 
included in the information stored in the verification 
field. 

The price field 24 may contain the price of the 
ticket. In the case of a multiple ticket, this may be the 
price of the total ticket (multiple use) or the price of a 
single use of the ticket. 

The sequence number field 25 comprises the 
sequence number of the ticket 20. This sequence 
number may be used for verification and limitation pur- 
poses, as will later be explained below. 

The validation count field 26 comprises a validation 
count, which is used to provide multiple use of the ticket 
20. That is, the ticket 20 may be used a number of times, 
that number being represented by the validation count. 
Preferably, the validation count is decreased upon each 
validation of the ticket, a count value zero representing 
a ticket which is used up, i.e. which cannot be validated 
another time. In this case, the count value is equal to the 
number of times the ticket can (still) be used, assuming 
that the count is decreased during each validation. 
Alternatively, the count may be decreased or increased 
until it reaches some predetermined value (null value), 
which need not equal zero. In principle said predeter- 
mined value may be different for each ticket. However, 
having a fixed value indicating a used-up ticket elimi- 
nates the need for storing the null value, thus saving 
memory space. 

If the null value equals zero, and rf the validation 
count is initially set to one, the multiple ticket 20 is 
essentially reduced to a single ticket. This allows the 
multiple ticket structure of Fig. 3 to be used for all types 
of tickets, both multiple and single, thus simplifying the 
smart card hardware and software. 

It will be understood that the fields of the ticket 20 
may be stored in the memory 1 2 of the card 1 , as shown 
in Figs. 1 and 2. 

In the flow diagram of Fig. 4, an example of the val- 
idation of a ticket according to the present invention is 
represented. It will be assumed that the null value 
equals zero. 

In step 40, the validation process is started, e.g. by 
inserting the smart card in question in a validation termi- 
nal. 

In step 41, the terminal checks the card for the 
presence of tickets. Data identifying the tickets are 
transferred to the terminal. 

In step 42, the terminal presents the tickets to the 
user, e.g. by displaying a list of tickets on a screen. The 
contents of the validation fields 22 are also shown. The 
user selects the ticket to be validated, e.g. by typing in 
the number of the ticket in the list. 

In step 43, the security module (SM) of the terminal 
checks the validation count (stored in the validation 
count field 26) of the selected ticket. A count value 
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greater than zero indicates that the ticket may be vali- 
dated again, in which case the procedure continues with 
step 44. If the count value equals zero (the predeter- 
mined null value), the procedure continues with step 46. 

In step 44, new validation data are written in the val- 
idation field 22 of the selected ticket. Old validation data 
may be overwritten. Preferably, before the writing of new 
data a check of the old validation data takes place, 
ensuring that the old data pertain to an expired or other- 
wise unwanted ticket. If the validation fails, an error 
message may be generated and the procedure may be 
terminated. 

In step 45, the procedure is concluded by displaying 
the result ("ticket validated*) to the user. The card may 
be removed from the terminal, or the procedure may 
return to step 42. 

In case the procedure continues with step 46 after 
step 43, an error message is displayed on the screen of 
the terminal and the procedure returns to step 42, allow- 
ing the user the select another ticket. 

It will be understood that in the case of so-called 
contact-less cards, the insertion of the card into the ter- 
minal may be omitted. 

The procedure may further comprise a check for 
expired tickets. Such tickets may be invalidated by set- 
ting the validation count to the null value (e.g. zero). 

The price and the sequence number, as stored in 
the price field 24 and the sequence number field 25, 
may be used to limit the number of tickets issued and 
thus to limit the extent of possible fraud. The issuing ter- 
minal may e.g. cumulatively store the prices of the tick- 
ets and compare the thus produced sum of the prices 
with a predetermined maximum value. Also, the 
sequence number of the ticket to be issued may be 
compared by the issuing terminal with a predetermined 
maximum value. In both cases, the issue of the ticket 
may be prevented if the maximum value (i.e. the issue 
limit) has been reached. This will further be explained 
below with reference to Fig. 7. 

While the price and the sequence number may be 
used to limit the number of tickets issued, the validation 
count as discussed above may be used for limiting the 
number of tickets to be validated. The count value writ- 
ten into the card upon issuance of the ticket may also be 
registered in the issuing terminal. The sum of the regis- 
tered count values may be limited to a predetermined 
number, the limit value, which may be different for each 
terminal. Said limit value may he valid for a period of 
time, e.g. a day or a week, allowing the terminal to issue 
a maximum number of ticket in one day or week. 

Issuing a ticket of the type shown in Fig. 3 com- 
prises the following steps: 

a. providing payment data, 

b. checking issuing limits, 

c. creating a ticket (20) in the memory of the smart 
card, the ticket comprising various fields (21-26), 

d. writing entitlement data in the entitlement field 



(21), 

e. writing a validation count in the validation count 
field (26), 
and optionally: 
5 f. writing price data in the price field (24), 

g. writing a sequence number in the sequence 
number field (25). 

In step a, the terminal is provided with payment 
io data guaranteeing the payment of the ticket. These pay- 
ment data may be the result of a deduction of a mone- 
tary balance in the smart card, or may consist of e.g. an 
electronic cheque or cash money. 

In step b, the issuing limits are checked, i.e. it is ver- 
15 ified by means of a terminal validation count and 
whether the maximum number of tickets has already 
been issued. If this is the case, the procedure is termi- 
nated. Possibly a ticket may be issued having a lower 
value of the validation count than asked for by the user. 
20 This may result in a partial refund. 

In step c, the fields of the ticket are preferably given 
an initial value representing invalidity, e.g. zero. This 
ensures that no valid ticket can be issued when the pro- 
cedure is prematurely terminated. • 
25 In step d, the data entitling the user to a certain 
service, access etc. are written into the ticket. These 
entitlement data specify the ticket. 

In step e, the validation count is set to a value cor- 
responding with the received payment data. 
30 In step g, the sequence number may be written in 
the ticket. Substantially simultaneously a sequence 
number count is increased in the terminal in order to 
register the number of tickets issued. As the validation 
count, the sequence number count may be used to limit 
35 the number of tickets issued, e.g. per day or per week. 
This provides additional protection against fraud in case 
an issuing terminal is stolen or abused. 

In Fig. 5 a terminal for use with the smart card and 
method of the present invention is schematically shown. 
40 The terminal 50 comprises a keyboard 51, a display 
screen 52 and a card reader 53, in which a card 1 may 
be inserted in order to exchange data. The terminal fur- 
ther comprises a processor 54 for processing data 
under the control of suitable programs, a memory 55 for 
45 storing data and programs, and a security module 56 for 
protectedly storing usage data of the terminal, such as 
monetary balances. In the security module 56, or alter- 
natively in the memory 55, the terminal validation count 
and sequence number count, which may be used to 
so limit the number of issued or validated tickets, are also 
stored. Additionally, a validation count limit and a 
sequence number limit, with which the terminal valida- 
tion count and the sequence number count may be 
compared, are stored in the security module 56 or the 
55 memory 55. The terminal 50 may be used as an issuing 
and/or as a validating terminal. 

- Fig. 6 schematically shows the exchange of data 
between a smart card and a terminal during the valida- 
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tion of a ticket, the terminal comprising a smart card 
reader/writer (denoted as reader) and a security module 
. (SM). 

In step 60, the procedure is started by the reader 
issuing a request to the security module. This request 
may be initiated by the user of the card, who activated 
the terminal by e.g. inserting the card into the terminal, 
pressing a button, or sending a signal to the terminal 
(e.g. by means of infra-red light). 

In step 61, the security module generates and 
stores a first random number Rl in response to said 
request. This number, which serves prevent replay of 
the data exchange, is sent to the card. In step 62, the 
card stores the number R1. 

In step 63. the terminal sends, via the reader, a 
read command to the card in order to read a ticket. This 
read command may or may not specify a particular 
ticket. In response to the read command, the card pro- 
duces in step 64 a first message authentication code 
MAC1. This code may be calculated by means of a 
cryptographic function having the ticket data and the 
random number R1 as input parameters. Such func- 
tions are well known in the art. The resulting code 
MAC1 may be appended to the ticket, whereupon the 
ticket (denoted as TickeM) and the code MAC1 are sent 
to the security module, via the reader. 

In step 65, both the code MAC1 and the validation 
count of the received ticket are checked. The check of 
the code MAC1 may be effected by recalculating the 
code, using the random number R1 stored in the secu- 
rity module. The validation count may be checked by 
comparing the contents of the validation count field (26 
in Fig. 3) of the ticket with a predetermined null value 
(e.g. zero). If the validation count equals the null value, 
or if the message authentication code is incorrect, the 
procedure may either terminate or return to step 60. 

In step 66, the terminal accepts validation data 
(denoted as VD) from the user, e.g. by means of a key- 
board, which data VD are passed to the security mod- 
ule. The reader then asks the card for a (new) random 
number. In response, the card generates in step 67 a 
second random number R2 and sends the number R2 
to the (security module of the) terminal. 

In step 68, the security module performs three 
actions: the validation count is decreased, the validated 
ticket (Ticket2) is produced and a new message authen- 
tication code (MAC2) is produced. That is, the validation 
count of the ticket is decreased, validation data are writ- 
ten into the validation field (22 in Fig. 3) and a new code 
MAC2 is calculated using a function having the vali- 
dated ticket (Ticket2) and the second random number 
(R2) as input parameters. The validated ticket (Ticket2) 
and the new code (MAC2) are sent to the card. 

. It should be noted that the validation count of a reg- 
ister in the security module (e.g. register R5 in Fig. 7) 
may be increased in step 68 in order to keep track of the 
number of tickets validated by the terminal. 

It should further be noted that step 68 preferably 



comprises inseparable actions in that the step 68 can- 
not be interrupted. This further enhances the security of 
the process. 

In step 69, the card checks the code MAC2, e.g. by 

5 recalculating the code using the ticket and the stored 
random number R2. If the code MAC2 is found to be 
incorrect, the procedure may terminate or may return to 
step 66. If the code is correct, the validated ticket is 
stored in the card, e.g. by overwriting the exiting ticket 

10 (Ticketl). The card then acknowledges the succesful 
updating of the ticket. Subsequently, the procedure is 
ended in step 70. 

Fig. 7 schematically shows a security module 56 of 
a tickets issuing terminal, e.g. the terminal 50 of Fig. 5. 

is The security module 56 is arranged for keeping issue 
limits. The security module 56 comprises register units 
561-566, a random number generator (RNG) 567, a 
microprocessor (jaP) 568 and a memory (Mem.) 569. 
The register units 561 -565, the random number genera- 
te tor 567 and the memory 569 are connected with the 
microprocessor 568 by control and data lines which are 
not shown for the sake of clarity. 

Register unit 561 comprises a first register (R1) 
arranged for storing the sum of all tickets, i.e. the so- 

25 called ticket float Register unit 562 comprises a second 
register (R2) for storing a maximum value of the said 
sum. By comparing the contents of R1 and R2, it can be 
ascertained that the sum of all tickets (stored in R1) 
never exceeds the maximum sum (stored in R2). 

so Similarly, register unit 563 comprises a third regis- 
ter (R3) arranged for storing the current sequence 
number, i.e. the sequence number of the ticket last 
issued. Register unit 564 comprises a fourth register 
(R4) arranged for storing the maximum sequence 

35 number. Again, before a ticket is issued it may be veri- 
fied whether the current sequence number (in R3) does 
not exceed the maximum sequence number (in R4), 
thus limiting the number of tickets issued. 

Optional register units 565 and 566 may be use to 

40 store the sum of the validation counts: register 565 com- 
prises a fifth register (R5) storing the sum of the valida- 
tion counts of the tickets validated by the terminal, while 
register 566 comprises a sixth register (R6) storing the 
maximum sum of the validation counts. 

45 Register units 561, 563 and 565 thus store current 
values, while register units 562, 564 and 566 store max- 
imum values. The said maximum values are preferably 
predetermined, i.e. fixedly stored in the security module, 
but may also be updated periodically. The use, of the 

so registers R1 through R4 allows an efficient limitation on 
the number of tickets to be issued, as well as on the total 
value of those tickets. The use of the registers R5 and 
R6 allows an efficient limitation of the total number of 
validated tickets. TTie extent of possible fraud may thus 

55 be limited. 

It will be understood that the registers R1-R6 may 
also be embodied as locations of a memory, e.g. the 
memory 569, instead of separate register units 561 -565 
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as shown in Fig. 7. Also, in terminals which only issue 
tickets the registers R5 and R6 may be omitted. Simi- 
larly, in terminals which only validate tickets the regis- 
ters R1 through R4 may be omitted. 

As explained above, the use of multiple tickets s 
. according to the present invention allows an efficient 
and flexible use of the memory space of a smart card. 

It will be understood by those skilled in the art that 
the embodiments described above are given by way of 
example only and that many modifications and addi- io 
tions are possible without departing from the scope of 
the present invention. 

Claims 

75 

1 . Smart card (1) comprising an integrated circuit (1 0) 
having a processor (11) and a memory (12), the 
memory comprising tickets (20), a ticket comprising 
an entitlement field (21) for storing data relating to 
the entitlement of the ticket and a validation field 20 
(22) for storing data relating to the validity of the 
ticket, characteriz ed in that a ticket (20) further 
comprises a validation count field (26) for storing a 
validation count representing the number of times 
the ticket (20) may be validated. 25 

2. Smart card according to claim 1 , wherein the vali- 
dation count is aranged for being decreased upon 
each validation of the ticket (20), a further validation 

of the ticket being blocked when the count has a 30 
predetermined value, the predetermined value pref- 
erably being zero. 

3. Smart card according to claim 1 or 2, wherein a 
ticket (20) further comprises a price field (24) for 35 
storing the price of the ticket and/or the price of a 
single use of the ticket. 

4. Smart card according to any of the preceding 
claims, wherein a ticket (20) further comprises a 40 
sequence number field (24) for storing the 
sequence number given to the ticket (20) by an 
issuing terminal (50). 

5. Smart card (1) according to any of the preceding 45 
claims, wherein a ticket (20) further comprises at 
least one verification field (23; 24) for storing data 
relating to a check of the validity of the ticket. 

6. Method of registering tickets (20) on a smart card so 
(1) comprising a memory (12), the method compris- 
ing the steps of: 

creating a ticket (20) in the memory (12). the 
ticket comprising at least one field (e.g. 21), 55 
- issuing the ticket (20) by storing in the field (2 1 ) 
data identifying a right to be conveyed by the 
ticket, 



validating the ticket (20) by storing in a valida- 
tion field (22) data relating to the validity of the 
ticket, 

characterized in that the step of issuing the ticket 
comprises storing in a validation count field (26) a 
validation count representing the number of times 
the ticket (20) may be validated, and in that the step 
of validating the ticket comprises adjusting the vali- 
dation count stored in the validation count field (26), 
said adjusting as well as the step of validating the 
ticket being inhibited if the validation count has a 
predetermined value. 

7. Method according to claim 6, wherein the predeter- 
mined value is zero, the adjusting involving a 
decreasing of the validation count. 

8. Method according to claim 6 or 7, wherein the step 
of issuing the ticket (20) further comprises the stor- 
ing of a sequence number in a sequence number 
field (25), the sequence number being registered in 
an issuing terminal (50), preferably in a security 
module (56) of the terminal. 

9. Method according to claim 6, 7 or 8, wherein the 
step of issuing the ticket (20) further comprises the 
storing of the price of the ticket and/or the price of a 
single use of the ticket in a price field (24). 

10. Method according to any of the claims 6 through 9, 
wherein the step of issuing the ticket (20) further 
comprises the adding of the price of each issued 
ticket to a sum stored in the issuing terminal (50), 
preferably in the security module (56) of said termi- 
nal (50). 

1 1 . Method according to any of the claims 6 through 1 0, 
further comprising the step of verifying the ticket 
(20) by storing data relating to a check of the validity 
of the ticket in at least one verification field (23; 24). 
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